package com.serene.im.config;

import io.netty.channel.ChannelInitializer;
import io.netty.channel.ChannelPipeline;
import io.netty.channel.socket.SocketChannel;
import io.netty.handler.codec.http.HttpObjectAggregator;
import io.netty.handler.codec.http.HttpServerCodec;
import io.netty.handler.codec.http.websocketx.WebSocketServerProtocolHandler;
import io.netty.handler.stream.ChunkedWriteHandler;
import io.netty.handler.timeout.IdleStateHandler;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * 管道初始化
 */

public class NettyChannelInitializer extends ChannelInitializer<SocketChannel> {

    private static final Logger log = LoggerFactory.getLogger(NettyChannelInitializer.class);

    @Override
    protected void initChannel(SocketChannel ch) throws Exception {
        System.out.println("4.管道初始化");
        log.info(" 管道初始化...... ");
        ChannelPipeline pipeline = ch.pipeline();
        // websocket 基于http协议，所以要有http 编解码器
        pipeline.addLast("HttpServerCodec", new HttpServerCodec());

        // 对写大数据流的支持
        pipeline.addLast(new ChunkedWriteHandler());

        // 对httpMessage进行聚合，聚合成FullHttpRequest或FullHttpResponse
        // 几乎在netty中的编程，都会使用到此hanler
        pipeline.addLast(new HttpObjectAggregator(1024 * 64));

        // 增加心跳支持 start
        // 针对客户端，如果在1分钟时没有向服务端发送读写心跳(ALL)，则主动断开
        // 如果是读空闲或者写空闲，不处理
        pipeline.addLast(new IdleStateHandler(8, 10, 12));

        // 自定义的空闲状态检测 处理消息的handler
        //pipeline.addLast(new NettyHeartBeatHandler());

        /**
         * websocket 服务器处理的协议，用于指定给客户端连接访问的路由 : /ws
         * 本handler会帮你处理一些繁重的复杂的事
         * 会帮你处理握手动作： handshaking（close, ping, pong） ping + pong = 心跳
         * 对于websocket来讲，都是以frames进行传输的，不同的数据类型对应的frames也不同
         */
        pipeline.addLast(new WebSocketServerProtocolHandler("/ws"));
        System.out.println("5.进入websocket");

        // 自定义的wshandler 处理消息的handler
        pipeline.addLast(new NettyWsChannelInboundHandler());
        System.out.println("7.进入处理消息的handler类");

        // 自定义 http
        pipeline.addLast(new NettyHttpChannelInboundHandler());
        System.out.println("自定义http 的Handler");
    }

}
